

# SigmaStar Camera SPI 使用参考



© 2019 SigmaStar Technology Corp. All rights reserved.

SigmaStar Technology makes no representations or warranties including, for example but not limited to, warranties of merchantability, fitness for a particular purpose, non-infringement of any intellectual property right or the accuracy or completeness of this document, and reserves the right to make changes without further notice to any products herein to improve reliability, function or design. No responsibility is assumed by SigmaStar Technology arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights, nor the rights of others.

SigmaStar is a trademark of SigmaStar Technology Corp. Other trademarks or names herein are only for identification purposes only and owned by their respective owners.



{Product Description} {Document Name + Version}

# **REVISION HISTORY**

| <b>Revision No.</b> | Description         | Date         |
|---------------------|---------------------|--------------|
| {000001}            | • {Initial release} | {07/28/2018} |





# **TABLE OF CONTENTS**

| REVISION HISTORYi |        |                                          |     |  |
|-------------------|--------|------------------------------------------|-----|--|
|                   |        | F CONTENTS                               |     |  |
|                   |        |                                          |     |  |
|                   |        | 概述                                       |     |  |
|                   | 1.2.   | Features                                 | . 1 |  |
|                   | 1.3.   | Block Diagram                            | . 1 |  |
| 2.                | SPI 控制 |                                          | . 2 |  |
|                   | 2.1.   | SPI 控制概述                                 | . 2 |  |
|                   |        | Initialization                           |     |  |
|                   | 2.3.   | Trigger                                  | . 3 |  |
|                   | 2.4.   | MSPI Status                              | . 3 |  |
|                   | 2.5.   | MSPI Read Data Port                      | . 3 |  |
| 3.                | EXA    | MPLE                                     | . 4 |  |
|                   | 3.1.   | SPI Operation Example                    | . 4 |  |
|                   |        | Example code for MSPI Connect to Incense | . 5 |  |





# 1. 概述

# 1.1. 概述

This document describes the master SPI (MSPI) controller. This MSPI is a synchronous serial interface and can connect to a variety of external device.

## 1.2. Features

- ☐ Generic SPI protocol with half duplex.
- ☐ Supports Motorola SPI compatible timing. (CPHA/CPOL)
- 8 Byte write buffer and 8-Byte read buffer.
- ☐ Configurable Bit width from one bit to 8bits in a byte transfer.
- ☐ Supports up to 8 slave device select signals.
- ☐ Supports 3-wire mode.
- □ Supports an internal RIU (Register Interface Unit) interface. RIU is an in-house protocol of SigmaStar.

# 1.3. Block Diagram

### MSPI Block Diagram







# 2. SPI 控制

# 2.1. SPI 控制概述

This section describes which registers should be initialized before enabling MSPI, and how to trigger MSPI and which status should be checked.

## 2.2. Initialization

MSPI supports some configurable parameters like below.

## Generic Format



(1). DC Timing Setting, (0x0894, 0x0895, 0x0896, 0x0897)

"tr\_start": SCZ active setup time (relative to SCK)

"tr end": SCZ active hold time (relative to SCK)

"tb": The delay cycle between frame transfer

"trw": The delay cycle between last write and first read. (Read turn around cycle)

(2). Write/Read Frame Length Setting, (0x0890, 0x0891)

Frame Length from 0 ~ 8 Bytes

(3). Read/ Write Bit Length Setting per Frame, (0x0898, 0x089c)

Bit Length from 1 ~ 8 bit

(4). Clock & Phase Control, (0x0892, 0x0893)

Clock Setting: clk\_mcu/2, clk\_mcu/4, clk\_mcu/8, clk\_mcu/16, clk\_mcu/32, clk\_mcu/64, clk\_mcu/128,

clk\_mcu/256

CPOL: Clock Polarity CPHA: Clock Phase



{Product Description} {Document Name + Version}



(5). Set Reset & Enable. (0x0892)

0x0892 [2]: Interrupt enable bit

0: Disable

1: Enable

0x0892 [1]: Reset

0: Reset

1: Not Reset

0x0892 [0]: Enable

0: Disable

1: Enable

(6). Enable chip select. (0x08BE)

# 2.3. Trigger

MSPI Trigger. (0x08B4, Bit[0])

When this bit is set, MSPI controller will perform operation.

This bit is write-clear register

## 2.4. MSPI Status

MSPI completed Flag, (0x08B6, Bit[0])

- (1). When MSPI operation is completed, HW set this bit as high, before starting to next data transfer, SW needs to clear this bit via (0x80B8, Bit[0]),
- (2). When MSPI operation is completed, MSPI also issue an interrupt to CPU, SW needs to clear interrupt via (0x08B8, Bit[0]).

### 2.5. MSPI Read Data Port

When MSPI operation is completed, SW can get data from the below read port.

0x0888

0x0889

0x088A

0x088B

0x088C

0x088D

0x088E

0x088F





## 3. EXAMPLE

# 3.1. SPI Operation Example

This section describes an example of MSPI operation.

- (0). Initial
- (1). CS goes low
- (2). Write 2Bytes data
- (3). Read 1Bytes data
- (4). CS goes high



```
WREG[0x0892] = 0x07
                                              //Enable MSPI, Not Reset, Enable INT
                                              //CPOL = 0, CPHA = 0
WREG[0x0893] = 0x00
                                              //MSPI clock = CPU Clock/2
WREG[0x0894] = 0x00
                                              //tr_start = 1 Cycle
WREG[0x0895] = 0x00
                                              //tr_end = 1 Cycle
WREG[0x0896] = 0x00
                                              //tb = 0 cycle
WREG[0x0897] = 0x00
                                              //trw = 0 Cycle
WREG[0x0880] = DATA0
                                              //Write buffer0
WREG[0x0881] = DATA1
                                              //Write buffer1
WREG[0x0890] = 0x02
                                              //Write length = 2
WREG[0x0891] = 0x01
                                              //Read length = 1
WREG[0x0898], BIT[2:0] = 3'b111
                                             //Bit length=8Bit for write buffer0
               BIT[5:3] = 3'b111
                                             //Bit length=8Bit for write buffer1
WREG[0x089c], BIT[2:0] = 3'b111
                                             //Bit length=8Bit for read buffer0
WREG[0x08BE], BIT[0] = 1'b0
                                             //Select cs0
WREG[0x08B4], BIT[0] = 1'b1
                                             //Trigger MSPI operation
Done = RREG[0x08B6, Bit[0]]
                                             //Polling MSPI done flag Or interrupt
WREG[0x08B8], BIT[0] = 1'b1
                                            //Clear done flag or clear interrupt
WREG[0x08BE], BIT[0] = 1'b1
                                            //Disable cs0
```



{Product Description} {Document Name + Version}

## Example code for MSPI Connect to Incense

Register Write to Incense: WREG[0x5a] = 16'h5555



```
WREG[0x0892] = 0x07
                                              //Enable MSPI, Not Reset, Enable INT
                                              //CPOL = 0, CPHA = 0
WREG[0x0893] = 0x00
                                              //MSPI clock = CPU Clock/2
WREG[0x0894] = 0x00
                                              //tr start = 1 Cycle
WREG[0x0895] = 0x01
                                              //tr end = 2 Cycle
WREG[0x0896] = 0x00
                                              //tb = 0 cycle
WREG[0x0897] = 0x00
                                              //trw = 0 Cycle
WREG[0x0880] = 0x03 (CMD)
                                              //Write buffer0
WREG[0x0881] = 0x5A (ADR)
                                              //Write buffer1
WREG[0x0890] = 0x02
                                              //Write length = 2
WREG[0x0898], BIT[2:0] = 3'b111
                                             //Bit length=8Bit for write buffer0
                BIT[5:3] = 3'b000
                                              //Bit length=1Bit for write buffer1
WREG[0x08BE], BIT[0] = 1'b0
                                             //Select cs0
WREG[0x08B4], BIT[0] = 1'b1
                                             //Trigger MSPI operation
Done = RREG[0x08B6, Bit[0]]
                                             //Polling MSPI done flag Or interrupt
WREG[0x08B8], BIT[0] = 1'b1
                                             //Clear done flag or clear interrupt
WREG[0x08BE], BIT[0] = 1'b1
                                             //Disable cs0
ADR = ADR << 1;
WREG[0x0880] = ADR
                                            //Write buffer0
WREG[0x0881] = 0x55(DATA0)
                                            //Write buffer1
                                            //Write buffer2
WREG[0x0882] = 0x55(DATA1)
WREG[0x0890] = 0x03
                                           //Write length = 3
WREG[0x0898], BIT[2:0] = 3'b110
                                             //Bit length=7Bit for write buffer0
                BIT[5:3] = 3'b111
                                              //Bit length=8Bit for write buffer1
               BIT[8:6] = 3'b111
                                              //Bit length=8Bit for write buffer2
WREG[0x08BE], BIT[0] = 1'b0
                                             //Select cs0
WREG[0x08B4], BIT[0] = 1'b1
                                             //Trigger MSPI operation
Done = RREG[0x08B6, Bit[0]]
                                             //Polling MSPI done flag Or interrupt
WREG[0x08B8], BIT[0] = 1'b1
                                             //Clear done flag or clear interrupt
WREG[0x08BE], BIT[0] = 1'b1
                                             //Disable cs0
```

Register Read from Incense: RREG[0x5a]

{Product Description} {Document Name + Version}





```
WREG[0x0892] = 0x07
                                              //Enable MSPI, Not Reset, Enable INT
                                             //CPOL =0, CPHA=0
WREG[0x0893] = 0x00
                                              //MSPI clock = CPU Clock/2
WREG[0x0894] = 0x00
                                              //tr start = 1 Cycle
WREG[0x0895] = 0x01
                                              //tr end = 2 Cycle
WREG[0x0896] = 0x00
                                              //tb = 0 cycle
WREG[0x0897] = 0x00
                                              //trw = 0 Cycle
WREG[0x0880] = 0x06 (CMD)
                                              //Write buffer0
WREG[0x0881] = 0x5A (ADR)
                                              //Write buffer1
WREG[0x0890] = 0x02
                                              //Write length = 2
WREG[0x0898], BIT[2:0] = 3'b111
                                             //Bit length=8Bit for write buffer0
               BIT[5:3] = 3'b000
                                             //Bit length=1Bit for write buffer1
WREG[0x08BE], BIT[0] = 1'b0
                                             //Select cs0
WREG[0x08B4], BIT[0] = 1'b1
                                             //Trigger MSPI operation
                                             //Polling MSPI done flag Or interrupt
Done = RREG[0x08B6, Bit[0]]
WREG[0x08B8], BIT[0] = 1'b1
                                            //Clear done flag or clear interrupt
WREG[0x08BE], BIT[0] = 1'b1
                                            //Disable cs0
ADR = ADR << 1;
WREG[0x0880] = ADR
                                             //Write buffer0
WREG[0x0890] = 0x01
                                             //Write length = 1
WREG[0x0898], BIT[2:0] = 3'b110
                                             //Bit length=7Bit for write buffer0
WREG[0x08BE], BIT[0] = 1'b0
                                             //Select cs0
WREG[0x08B4], BIT[0] = 1'b1
                                             //Trigger MSPI operation
                                             //Polling MSPI done flag Or interrupt
Done = RREG[0x08B6, Bit[0]]
WREG[0x08B8], BIT[0] = 1'b1
                                            //Clear done flag or clear interrupt
WREG[0x0892], BIT[7:6]= 2'b01
                                             //CPOL = 0, CPHA = 1
                                             //Change mode for read data
WREG[0x0894] = 0x08
                                              //tr start = 8 Cycle
                                              //In this case trw = tr_start
WREG[0x0890] = 0x00
                                              //Write length = 0
WREG[0x0891] = 0x02
                                              //Read length = 2
WREG[0x08B4], BIT[0] = 1'b1
                                             //Trigger MSPI operation
```



{Product Description} {Document Name + Version}

Done = RREG[0x08B6, Bit[0]]//Polling MSPI done flag Or interrupt WREG[0x08B8], BIT[0] = 1'b1//Clear done flag or clear interrupt WREG[0x08BE], BIT[0] = 1'b1//Disable cs0 WREG[0x0891] = 0x01//Read length = 1//Dummy read WREG[0x089c], BIT[2:0] = 3'b000//Bit length=1Bit for read buffer0 WREG[0x08B4], BIT[0] = 1'b1//Trigger MSPI operation Done = RREG[0x08B6, Bit[0]]//Polling MSPI done flag Or interrupt WREG[0x08B8], BIT[0] = 1'b1//Clear done flag or clear interrupt